iT邦幫忙

2024 iThome 鐵人賽

DAY 20
0
Mobile Development

當Java遇見Android,30天學習指南系列 第 20

Day20 元件 RecyclerView介紹與使用

  • 分享至 

  • xImage
  •  

今天介紹的 RecyclerView 元件,是一個非常靈活且高效的工具,常用於顯示大量資料的列表或網格。這個元件能夠以條列的方式表示,將資料一筆接一筆的有條理地呈現在使用者面前。它不僅能大幅提升資料顯示的效率,還具備高度的互動性,讓使用者能輕鬆地瀏覽、選擇,甚至編輯項目。RecyclerView有提供更多自訂樣式與行為的彈性。這使得它成為開發者在處理動態或龐大資料時不可或缺的視窗元件。

介紹RecyclerView的一些特點:

  1. 靈活的佈局: 可以用 LinearLayoutManager、GridLayoutManager 或 StaggeredGridLayoutManager 來設置垂直、水平、網格或不規則的佈局。
  2. ViewHolder 模式: 透過 ViewHolder 模式來優化效能,減少不必要的 findViewById() 呼叫。
  3. 分隔線和裝飾: 可以自訂分隔線或其他視覺效果(例如使用 ItemDecoration)。
  4. **可擴展性強:**可以方便地加入動畫效果、拖曳排序等功能。

我們利用這個範例

製作RecyclerView簡單的瀏覽列表

https://ithelp.ithome.com.tw/upload/images/20240928/201688057zlqms9liP.png

話不多說,現在開始製作
我們先在layout,按右鍵New ->點Layout
https://ithelp.ithome.com.tw/upload/images/20240928/20168805awPLyAlZzN.png
https://ithelp.ithome.com.tw/upload/images/20240928/20168805e4vfsyNkE5.png
新增一個recyclerview_item.xml檔案
https://ithelp.ithome.com.tw/upload/images/20240928/201688058kU9YSmO4d.png
我們先拉recyclerview的介面,介面拉完會呈現這樣
https://ithelp.ithome.com.tw/upload/images/20240928/20168805HpNlyFhUAS.png
recyclerview_item.xml 程式碼

<LinearLayout
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:orientation="vertical"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="horizontal">

            <TextView
                android:id="@+id/item_textView_tv"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_weight="1"
                android:gravity="center"
                android:text="TextView"
                android:textColor="@color/black"
                android:textSize="20dp"/>

            <TextView
                android:id="@+id/item_textView2_tv"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_weight="1"
                android:gravity="center_vertical"
                android:text="TextView"
                android:textColor="@color/black"
                android:textSize="20dp"/>

        </LinearLayout>
    </LinearLayout>

recyclerview的介面拉完,回到activity_main在拉recyclerview這個元件,recycleview視窗,拉滿介面,拉完會呈現這樣
https://ithelp.ithome.com.tw/upload/images/20240928/20168805raVZQS7ruQ.png
如果你找不到recyclerview這個元件,點Palettee ->再點Common就能找到
https://ithelp.ithome.com.tw/upload/images/20240928/20168805PcX8aXWM1P.png
補充重點:如果拉出來的recycleview元件屬性沒有id,必須要自己補上,不然會無法跟變數名稱相互綁定。
https://ithelp.ithome.com.tw/upload/images/20240928/201688050MMhmzsfl8.png

再連接上程式碼,RecyclerView簡單的瀏覽列表就製作完成了
MainActivity.Java

public class MainActivity extends AppCompatActivity {
    RecyclerView recyclerView;
    ListAdapter listAdapter;

    final static String[] data = {"蘋果", "橘子", "柚子", "葡萄", "酪梨"};
    ArrayList<HashMap<String, String>> arrayList = new ArrayList<>();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        for (int i = 0; i < 20; i++) {
            HashMap<String, String> hashMap = new HashMap<>();
            hashMap.put("number", String.format("%02d", i + 1));
            hashMap.put("data", "data:" + String.valueOf(data[new Random().nextInt(5)]));

            arrayList.add(hashMap);
        }

        recyclerView = findViewById(R.id.recyclerView);
        recyclerView.setLayoutManager(new LinearLayoutManager(this));
        recyclerView.addItemDecoration(new DividerItemDecoration(this, DividerItemDecoration.VERTICAL));
        listAdapter = new ListAdapter();
        recyclerView.setAdapter(listAdapter);
    }

    private class ListAdapter extends RecyclerView.Adapter<ListAdapter.ViewHolder> {

        class ViewHolder extends RecyclerView.ViewHolder {
            private TextView tex1, tex2;

            public ViewHolder(View itemView) {
                super(itemView);
                tex1 = itemView.findViewById(R.id.item_textView_tv);
                tex2 = itemView.findViewById(R.id.item_textView2_tv);
            }
        }

        @Override
        public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
            View ve = LayoutInflater.from(parent.getContext()).inflate(R.layout.recyclerview_item, parent, false);
            return new ViewHolder(ve);
        }

        @Override
        public void onBindViewHolder(ViewHolder holder, int position) {
            holder.tex1.setText(arrayList.get(position).get("number"));
            holder.tex2.setText(arrayList.get(position).get("data"));
        }

        @Override
        public int getItemCount() {
            return arrayList.size();
        }
    }
}

成果:

元件RecycleView 介紹與使用 介紹完畢
下一篇元件Spinner 介紹


上一篇
# Day19 利用元件Text View and Button製作BMI計算器
下一篇
# Day 21 元件介紹Spinner
系列文
當Java遇見Android,30天學習指南30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言